FETCH (Transact 您所在的位置:网站首页 sql open语句 FETCH (Transact

FETCH (Transact

2024-04-13 04:01| 来源: 网络整理| 查看: 265

FETCH (Transact-SQL) 项目 12/22/2023

适用于:SQL ServerAzure SQL 数据库Azure SQL 托管实例

通过 Transact-SQL 服务器游标检索特定行。

Transact-SQL 语法约定

语法 FETCH [ [ NEXT | PRIOR | FIRST | LAST | ABSOLUTE { n | @nvar } | RELATIVE { n | @nvar } ] FROM ] { { [ GLOBAL ] cursor_name } | @cursor_variable_name } [ INTO @variable_name [ ,...n ] ]

注意

若要查看 SQL Server 2014 (12.x) 及更早版本的 Transact-SQL 语法,请参阅早期版本文档。

参数

NEXT 紧跟当前行返回结果行,并且当前行递增为返回行。 如果 FETCH NEXT 为对游标的第一次提取操作,则返回结果集中的第一行。 NEXT 为默认的游标提取选项。

PRIOR 返回紧邻当前行前面的结果行,并且当前行递减为返回行。 如果 FETCH PRIOR 为对游标的第一次提取操作,则没有行返回并且游标置于第一行之前。

FIRST 返回游标中的第一行并将其作为当前行。

LAST 返回游标中的最后一行并将其作为当前行。

ABSOLUTE { n| @nvar} 如果 n 或 @nvar 为正,则返回从游标起始处开始向后的第 n 行,并将返回行变成新的当前行。 如果 n 或 @nvar 为负,则返回从游标末尾处开始向前的第 n 行,并将返回行变成新的当前行。 如果 n 或 @nvar 为 0,则不返回行。 n 必须是整数常量,并且 @nvar 必须是 smallint、tinyint 或 int。

RELATIVE { n| @nvar} 如果 n 或 @nvar 为正,则返回从当前行开始向后的第 n 行,并将返回行变成新的当前行。 如果 n 或 @nvar 为负,则返回从当前行开始向前的第 n 行,并将返回行变成新的当前行。 如果 n 或 @nvar 为 0,则返回当前行。 在对游标进行第一次提取时,如果在将 n 或 @nvar 设置为负数或 0 的情况下指定 FETCH RELATIVE,则不返回行。 n 必须是整数常量,并且 @nvar 必须是 smallint、tinyint 或 int。

GLOBAL 指定 cursor_name 是指全局游标。

cursor_name 要从中进行提取的开放游标的名称。 当同时存在以 cursor_name 作为名称的全局游标和局部游标时,如果指定 GLOBAL,则 cursor_name 指全局游标,如果未指定 GLOBAL,则指局部游标。

@cursor_variable_name 游标变量名,引用要从中进行提取操作的打开的游标。

INTO @variable_name[ ,...n] 允许将提取操作的列数据放到局部变量中。 列表中的各个变量从左到右与游标结果集中的相应列相关联。 各变量的数据类型必须与相应的结果集列的数据类型匹配,或是结果集列数据类型所支持的隐式转换。 变量的数目必须与游标选择列表中的列数一致。

注解

如果 ISO 样式 DECLARE CURSOR 语句中未指定 SCROLL 选项,则 NEXT 是唯一受支持的 FETCH 选项。 如果 ISO 样式 DECLARE CURSOR 中指定了 SCROLL,则支持所有 FETCH 选项。

如果使用 Transact-SQL DECLARE 游标扩展插件,则应用下列规则:

如果指定了 FORWARD_ONLY 或 FAST_FORWARD,则 NEXT 是惟一受支持的 FETCH 选项。

如果 DYNAMIC、FORWARD_ONLY 或 FAST_FORWARD 未指定,且指定了 KEYSET、STATIC 或 SCROLL 中的一个,则支持所有 FETCH 选项。

DYNAMIC SCROLL 游标支持除了 ABSOLUTE 的所有 FETCH 选项。

@@FETCH_STATUS 函数报告上一个 FETCH 语句的状态。 相同的信息记录在由 sp_describe_cursor 返回的游标中的 fetch_status 列中。 这些状态信息应该用于在对由 FETCH 语句返回的数据进行任何操作之前,以确定这些数据的有效性。 有关详细信息,请参阅 @@FETCH_STATUS (Transact-SQL)。

权限

FETCH 语句的权限默认情况下授予任何有效用户。

示例 A. 在简单的游标中使用 FETCH

以下示例为 Person.Person 表中姓氏以字母 B 开头的行声明了一个简单的游标,并使用 FETCH NEXT 逐个提取这些行。 FETCH 语句以单行结果集形式返回在 DECLARE CURSOR 中指定的列的值。

USE AdventureWorks2022; GO DECLARE contact_cursor CURSOR FOR SELECT LastName FROM Person.Person WHERE LastName LIKE 'B%' ORDER BY LastName; OPEN contact_cursor; -- Perform the first fetch. FETCH NEXT FROM contact_cursor; -- Check @@FETCH_STATUS to see if there are any more rows to fetch. WHILE @@FETCH_STATUS = 0 BEGIN -- This is executed as long as the previous fetch succeeds. FETCH NEXT FROM contact_cursor; END CLOSE contact_cursor; DEALLOCATE contact_cursor; GO B. 使用 FETCH 将值存入变量

以下示例与示例 A 相似,但 FETCH 语句的输出存储于局部变量而不是直接返回到客户端。 PRINT 语句将变量组合成单一字符串并将其返回到客户端。

USE AdventureWorks2022; GO -- Declare the variables to store the values returned by FETCH. DECLARE @LastName VARCHAR(50), @FirstName VARCHAR(50); DECLARE contact_cursor CURSOR FOR SELECT LastName, FirstName FROM Person.Person WHERE LastName LIKE 'B%' ORDER BY LastName, FirstName; OPEN contact_cursor; -- Perform the first fetch and store the values in variables. -- Note: The variables are in the same order as the columns -- in the SELECT statement. FETCH NEXT FROM contact_cursor INTO @LastName, @FirstName; -- Check @@FETCH_STATUS to see if there are any more rows to fetch. WHILE @@FETCH_STATUS = 0 BEGIN -- Concatenate and display the current values in the variables. PRINT 'Contact Name: ' + @FirstName + ' ' + @LastName -- This is executed as long as the previous fetch succeeds. FETCH NEXT FROM contact_cursor INTO @LastName, @FirstName; END CLOSE contact_cursor; DEALLOCATE contact_cursor; GO C. 声明 SCROLL 游标并使用其他 FETCH 选项

以下示例创建一个 SCROLL 游标,使其通过 LAST、PRIOR、RELATIVE 和 ABSOLUTE 选项支持全部滚动功能。

USE AdventureWorks2022; GO -- Execute the SELECT statement alone to show the -- full result set that is used by the cursor. SELECT LastName, FirstName FROM Person.Person ORDER BY LastName, FirstName; -- Declare the cursor. DECLARE contact_cursor SCROLL CURSOR FOR SELECT LastName, FirstName FROM Person.Person ORDER BY LastName, FirstName; OPEN contact_cursor; -- Fetch the last row in the cursor. FETCH LAST FROM contact_cursor; -- Fetch the row immediately prior to the current row in the cursor. FETCH PRIOR FROM contact_cursor; -- Fetch the second row in the cursor. FETCH ABSOLUTE 2 FROM contact_cursor; -- Fetch the row that is three rows after the current row. FETCH RELATIVE 3 FROM contact_cursor; -- Fetch the row that is two rows prior to the current row. FETCH RELATIVE -2 FROM contact_cursor; CLOSE contact_cursor; DEALLOCATE contact_cursor; GO 另请参阅

CLOSE (Transact-SQL) DEALLOCATE (Transact-SQL) DECLARE CURSOR (Transact-SQL) OPEN (Transact-SQL)



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有